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(54) A circuit arrangement for providing internet connectivity to a key telephone user 



(57) A circuit arrangement is provided for connect- 
ing a personal computer (PC) to a port of a key tele- 
phone system via an adapter circuit which also interfac- 
es a digital key set to the port. The adapter circuit is con- 
nected to the computer via an RS-232 single channel 
data link. The PC is programmed to generate and re- 
ceive a serial data stream into which are encapsulated 



messages relating to link control and telephone func- 
tionality. The adapter circuit is also programmed to re- 
ceive and generate the serial data stream. The data rate 
through the adapter circuit and the telephone system 
and hence to a remote computer is dependent on the 
utilization of the attached key set by the user to make a 
call. 
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Description 

Field of the invention 

This invention relates generally to digital key tele- 
phone systems and more particularly to a circuit ar- 
rangement for allowing a user the simultaneous use of 
his digital key set and personal computer (PC). An 
adapter circuit allows data connectivity to a data service 
such as the Internet network simultaneously with tele- 
phone functionality using either the PC or the key set. 

Background of the Invention 

Generally, very small telephone switching systems 
have been referred to as key telephone systems. Typi- 
cally, a key telephone system was provided by extensive 
telephone line and control lead wiring between the key 
telephone sets with each telephone line extending to a 
telephone switching office. Each of the key sets included 
a plurality of interlocking pushbuttons or keys each for 
connecting the telephone set to a particular telephone 
line among a plurality of telephone lines routed to each 
key telephone set. The switching function of line selec- 
tion was mechanically provided and distributed among 
the key telephone sets. The primary advantages of 
these systems were economy with small size and ro- 
bustness. However, these early systems were difficult 
to expand, required extensive cabling, and were not 
compatible with the emerging world of digital switching 
and the associated digital communications. 

In the late 1980's and 1990's, a new generation of 
small switching systems were developed to be compat- 
ible with the existing world of digital telephony. One of 
the better-known and most successful of these systems 
is marketed under the name of Norstar™ by Northern 
Telecom. _ 

Further information on the Norstar digital key tele- 
phone system may be obtained from United States Pat- 
ent No. 4,873,682 issued October 10, 1989 to G.F. Irwin 
et al. and United States Patent No. 5,027,345 issued 
June 25, 1991 to T.J. Littlewood; both patents are as- 
signed to the same assignee as the present application 
and are hereby incorporated herein by reference. Yet 
other information on the Norstar system may be ob- 
tained from the publication Telesis" 1989, two, pub- 
lished by Bell-Northern Research, the research arm of 
Northern Telecom Limited. 

The Norstar system interfaces to the public 
switched telephone network (PSTN) via lines and trunks 
in the usual manner of a telephone switch. The core of 
the system named KSU (Key Service Unit) in Norstar, 
on the other hand, is connected to proprietary digital key 
sets via time-compression multiplex (TCM) links each 
carrying a pair of B-channels B1 and B2 at 64 kb/s and 
a D-channel at 16 kb/s. 

The KSU can also be connected to a personal com- 
puter (PC). The physical and logical connection be- 
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tween a PC and the Norstar system is provided by a 
proprietary PC interface card that occupies one stand- 
ard PC bus slot. A PC thus equipped can be connected 
to a Norstar system via a standard TCM port on the KSU. 

5 Firmware in the PC interface card provides PC applica- 
tions with access to both D-channel functional messag- 
ing and B-channel data. The PC communicates with the 
card via interrupts for the D-channel and direct memory 
access for large data transfer associated with the B- 

10 channel traffic. 

The Norstar system also provided for the connec- 
tion of a PC and digital key set to a TCM port of the 
switch. A coupling device was inserted in the TCM path 
between the KSU and a digital station set to provide an 

is interface to the TCM loop, a D and B1 -channel interface 
to the station set and a B2-channel interface to an RS- 
232 link to a PC. The device included a modem to inter- 
face the B-2 channel to the PC. The device thus allowed 
the use of the PC to make data calls on the B2-channel 

20 and the use of a key set to make voice calls on the 
B1 -channel. 

The desirability of connecting both a telephone sta- 
tion set and a PC to a common port of a switching sys- 
tem is well recognized and is exemplified by numerous 
25 patents in addition to the Norstar system mentioned 
above. 

For example, U.S. Patent No. 5,003,580 to D.M. 
Duong describes an adapter for interfacing a work sta- 
tion terminal to a key telephone system. The adapter 
30 comprises a pair of interface circuits and a pair of relays 
for variously switching them to the work station or the 
station set. 

U.S. Patent No. 4,689,81 4 also describes an exter- 
nal device for interfacing an external device such as a 
35 PC and an electronic telephone to a switching system. 
This device also uses a switching module comprising 
relays to switch the lines from the ports on the switch to 
the external devices. The switching module uses a re- 
sistor network to mute the audio signal to the telephone 
40 set when an external device is actuated. 

The above and other similar patents therefore indi- 
cate that it is known to provide an adapter device for 
interfacing a telephone station set and a personal com- 
puter to a telephone line from a switching system. It is 
45 also known to provide a PC programmed to function co- 
operatively with a station set so that it may be used to 
initiate telephony functions. However, the known devic- 
es are not adapted to provide simultaneous telephony 
functionality and data connectivity such as to the Inter- 
so net network, and an attached set. 

Summary of the Invention 

It is an object of this invention to overcome disad- 
55 vantages of the prior art. 

It is a further object of this invention to provide an 
adapter circuit for providing the simultaneous use of te- 
lephony functions and access to data services such as 
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the Internet network over a single serial link connecting 
a PC and the adapter circuit. 

It is a yet further object of this invention to provide 
an adapter circuit for connection between a TCM port of 
a key telephone system and a personal computer 
whereby the connection between the computer and the 
adapter circuit is a single serial link that provides simul- 
taneous telephone signaling and data communication 
capability. 

It is also an object of this invention to provide an 
adapter circuit for connection between a TCM port of a 
key telephone system, a personal computer and a key 
set whereby the adapter circuit behaves as a high- 
speed modem between the PC and a remote computer 
and wherein the arrangement provides the capability for 
simultaneous telephone functionality and data connec- 
tivity to the remote computer. 

The invention therefore, according to a first aspect, 
meets at least the first object above by providing a circuit 
arrangement for providing simultaneous telephone 
functionality and data connectivity to a personal compu- 
ter (PC) connected to a key telephone system, the sys- 
tem including a key service unit (KSU) and a plurality of 
digital key sets, the PC being connected to a port of the 
KSU and to one of the digital key sets via an adapter 
circuit, the port being adapted to carry a pair of data 
channels (2B) and a signaling and control channel (D) 
to provide a 2B+D TCM link, the circuit arrangement 
comprising: 

an adapter circuit having a first TCM port for con- 
nection to the port of the KSU, a second TCM port 
for connection to the digital key set and a third port 
for connection to the PC, the third port comprising 
a first circuit for interfacing to single channel serial 
data; 

a PC suitably programmed to provide telephone 
functionality by generating and responding to tele- 
phone signaling and control data and to provide da- 
ta generation and reception functionality, the PC 
comprising a second circuit for interfacing to single 
channel serial data port and being further suitably 
programmed to multiplex and demultiplex data gen- 
erated in the realization of the telephone and data 
functionalities for generating a single channel data 
stream suitable for transmission between the first 
and second interfacing circuits in accordance with 
a predetermined protocol; 

the adapter circuit further comprising a processor, 
control circuitry, and a multiplexor/demultiplexor cir- 
cuit for multiplexing TCM data to single channel se- 
rial data and demultiplexing single channel serial 
data to TCM data, in accordance with the predeter- 
mined protocol, the control circuitry being respon- 
sive to commands from the processor to route sig- 
naling data to and from the key set and the PC to 
the KSU and to always route one of the B-channels 
to the key set when it is in use and to otherwise con- 
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nect both B-channels to the PC. 

From a second aspect, the invention provides a 
method of providing telephony and data connectivity be- 

5 tween a personal computer (PC) and a 2B+D channel 
TCM port on a key telephone system, the PC being suit- 
ably programmed to provide telephony functions as well 
as data handling functions including telephone line dial- 
ing capability and having an interface circuit to a single 

10 channel serial data port, the arrangement further com- 
prising an adapter circuit including a controller and hav- 
ing first circuit means for interfacing to a signal path con- 
nected to the TCM port on the key telephone system 
second circuit means for connection to a key set, the 

15 interfacing circuit means providing access ports corre- 
sponding to a D-channel, a B1 -channel and a B2-chan- 
nel, the adapter circuit also having an interface circuit 
for a single channel serial data port, the serial data ports 
of the PC and the adapter circuit being connected by a 

20 serial communications link, the method of the invention 
comprising the steps of: 

in the adapter circuit, multiplexing the data on the 
D and B-channels into a single channel serial data 
25 stream using a predetermined protocol and demul- 
tiplexing the received serial data stream into D and 
B-channel data; 

in the PC, demultiplexing the serial data stream to 
reconstitute the 2B+D data, and multiplexing the 

30 2B+D data generated in the PC for transmission on 
the serial communications link; and wherein 
the controller of the adapter is suitably programmed 
to recognize functional signaling corresponding to 
requested use by a user of voice functionality, and 

35 in response thereto, forward the signaling to the key 
system on the D-channel and switch the allocation 
of one of the B-channels from use by the PC to use 
by the set 

40 From yet a third aspect, the invention further pro- 
vides a circuit arrangement for providing simultaneous 
telephone functionality and data connectivity between a 
personal computer (PC) and a time compression multi- 
plex (TCM) port on a key telephone system, comprising: 

45 

an adapter circuit comprising a controller circuit and 
having circuit means for interfacing to a TCM signal 
path connected to the TCM port on the key tele- 
phone system, the TCM path for carrying 2B+D 

50 channels of data, the interfacing circuit means be- 
ing controlled to decompose and recompose the 
TCM signal to provide signals corresponding to a 
D-channel, a B1 -channel and a B2-channel on re- 
spective data ports thereof, the adapter circuit also 

55 comprising, a serial port interface circuit, and a mul- 
tiplexor/demultiplexor circuit for translating the 
2B+D channel data to a single channel data stream 
under control of the controller circuit; 
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a PC suitably programmed to provide telephony 
functions as well as data handling functions includ- 
ing telephone line dialing capability, the PC com- 
prising an interface circuit for a single channel serial 
data port and being further suitably programmed to 5 
multiplex and demultiplex data generated for the te- 
lephony functions and for the data handling func- 
tions to and from a data stream on the single chan- 
nel serial data port; and 

a serial data link for connecting the single channel 
serial data port interface circuit of the PC to the se- 
rial port interface circuit of the adapter circuit. 

The sub-claims relating to the second and third as- 
pects of the invention disclose further advantageous 
embodiments of the invention. 

Brief Description of the Drawings 

Embodiments of the invention will now be described 
with reference to the accompanying drawings, in which: 

Figure 1 is a very generalized illustration of a con- 
temporary key telephone system; 

Figure 2 is a block diagram of a circuit arrangement 
in accordance with the invention; 

Figure 3 is a block diagram of a portion of the ar- 
rangement of Figure 2 illustrating the functional cir- 
cuit blocks therein; 

Figure 4 is a functional block diagram and message 
format illustrating the software structure used in the 
generation of the single channel data stream; 

— - Figures 5a, 5b, 5c and 5d are tables illustrating 
message formatting for transparency substitutions 
and various message types; 

Figure 6 is a state machine depicting the operation 
of the multiplexor/demultiplexors used at each end 
of the serial data link shown in figure 3. 

Figure 1 illustrates a very general architecture of a 
key telephone system such as the Norstar system. It 
consists of a Key System Unit (KSU) 10 connected to a 
plurality of proprietary digital key sets 1 1 . The KSU con- 
tains the common system components such as power, 
control and a non-blocking time switch. It also provides 
interfaces for connection to the public switched tele- 
phone network 12 and may be connected to a personal 
computer 13 as described below. The processor and 
memory requirements for the KSU 10 are conventional 
and may use commercial processors as described in the 
above -identified patents and publication about the Nor- 
star system. Read-only memory (ROM) holds the sys- 
tem software and non-volatile memory (NVRAM) is pro- 



vided to hold permanent data such as configuration ta- 
bles and settings of user preferences. 

Each Norstar key set 11 is connected to the KSU 
10 over a single twisted pair. This connection is fully dig- 
ital using time compression multiplex (TCM) to carry two 
64 kb/s B-channels and one 16 kb/s D-channel (2B+D), 
thus providing an ISDN-compatible data link. The B- 
channels carry digitally encoded speech or data and the 
D-channel carries control and signaling messages. In 
TCM, bursts of data are transmitted in "ping-pong" fash- 
ion every 125 microseconds between the KSU 10 and 
a key set 11. Each burst contains 23 bits - a start bit, a 
balance bit, a stop bit, and 20 bits for voice, data and 
signaling channels. Delay and guard times prevent in- 
terference between the receive and transmit bursts in 
the transceivers at the end of each loop. The delay time 
is limited by the maximum loop length to be covered. 

The provisioning of 2B+D bandwidth to every key 
set 11 supports enhanced telephone terminal design 
and functionality. For example, each Norstar station set 
has a character display which, by means of the associ- 
ated D-channel. offers simplified access to system fea- 
tures, administration and configuration. The displays, 
sometimes in conjunction with context sensitive keys or 
softkeys, facilitate feature activations, present call sta- 
tus and feature information, confirm when operations 
have been correctly executed and identify and help to 
resolve invalid operations. 

The Norstar software structure operates as a 
number of independent tasks which operate in parallel 
and communicate by means of a broadcast message 
system. There is an independent task for each line and 
terminal plus some service tasks which manage shared 
equipment and configuration data. Messages between 
tasks are known as Functional Messages. Tasks may 
run on the KSU processor in a round robin timeshared 
mannerror may run on any terminal which has sufficient 
processing capacity. With appropriate interfaces and 
software, a PC can act as a terminal and run tasks which 
interact with the system; this is described in detail in the 
aforementioned references. 

Underlying the task structure are programs to sup- 
port the message system, allocate KSU processor time 
between the various tasks and communicate with the 
system hardware. Central to this operation is a program 
called the Message Agent (MA). When a task generates 
a message, the message is sent to the MA and placed 
in a queue. Tasks running on the KSU processor can 
pass messages directly to the MA: tasks running on a 
terminal send their messages over the D-channel. 

When a message reaches the head of the queue, 
the MA submits the message to each task running on 
the KSU processor. It also arranges for the message to 
be transmitted over the D-channel to all attached termi- 
nals. Thus a message generated by one task is broad- 
cast to all other tasks whether these tasks operate on 
the KSU processor or on the terminals themselves. 

A terminal control task which runs on the KSU proc- 
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essor is known as an Emulator. Logically, there is no 
difference between an emulator and a task running in a 
terminal; both perform similar functions and communi- 
cate with other tasks by means of broadcast messages. 
However, an emulator must also communicate with the s 
hardware of its associated terminal; that function is per- 
formed using special messages called Stimulus Mes- 
sages (SM). SMs are not broadcast, but are treated spe- 
cially by the messaging software and transmitted direct- 
ly between an emulator and its associated terminal. In 
most cases, stimulus messages correspond to elemen- 
tary terminal actions such as reporting keystrokes or ac- 
tivating indicators or audible signals. 

In Norstar, each terminal and line is controlled by 
an independent software task. Tasks communicate by 
means of functional messages which are in a defined 
format and occur in a defined sequence. Each task and 
associated terminal is identified by a unique station in- 
dex. 

The sequence to set up a simple terminal to terminal 
call results in two tasks agreeing to communicate; how- 
ever, no speech path has yet been set up between the 
corresponding sets. Each task now sends a message 
to a service program which runs in the KSU. The service 
program sends control signals to the timeswitch devices 
which implement the required B-channel connections. 

The sequence to set up a terminal to terminal call 
is largely independent of user interfaces and features. 
The needed keystrokes, displays and ultimate respons- 
es are all handled by the control tasks of the sets. Nor- 
star terminals implement a variety of features, each as- 
sociated with a specific feature code. Users may dial the 
code directly or program a key on the set to generate 
the code and invoke the feature. In most cases, the fea- 
ture code will be acted upon directly by the controlling 
task of the terminal concerned. However, if an unallo- 
cated code is generated, the task will broadcast a mes- 
sage to that effect and if an appropriate server task is 
present in the system, it can respond and engage in on- 
going dialog with the terminal control task and thus, in- 
directly, with the user. This intervention is known as X- 
Feature operation. Such server tasks may exist in other 
terminals, in the KSU or in personal computers attached 
as terminals to a Norstar system. 

Figure 2 shows a circuit arrangement in accordance 
with the invention. A KSU 10 is shown connected to the 
PSTN 12 via a digital network interface as for example 
an ISDN link, and to a plurality of proprietary digital key 
sets 1 1 by respective TCM links. Also shown is an adapt- 
er circuit 20 having a first port connected via a TCM link 
to a port of the KSU 10, a second port connected to a 
digital key set 11 via a partial (B1+D) TCM link and a 
third port connected to a PC 1 3 via a standard RS-232E 
link. The RS232E link is adapted to carry a single chan- 
nel data stream in accordance with the standard: TIA, 
EIA/TIA-232E, Interface Between Data Terminal Equip- 
ment and Data Circuit-Terminating Equipment Employ- 
ing Serial Binary Data Interchange. In order to accom- 



modate this facility, each end of the link is therefore con- 
nected to a standard physical interface circuit as is well- 
known. 

Figure 3 illustrates the functional blocks of the PC 
13 and the adapter circuit 20 necessary to realize the 
invention. Each end of the RS-232E link is shown con- 
nected to a respective one of standard interface circuits 
30 and 31 ; each of these may be embodied as universal 
asynchronous receiver/transmitter (UART). 

The PC 13 comprises a pair of parallel software ap- 
plications, both of which are well known in the art. A first 
one is a data application (e.g. Web Browser) 32 such as 
may, for example, be used to interface interactively with 
another computer or data terminal via the internet net- 
work. The data application is interfaced to a multiplexor/ 
demultiplexer 33 via another standard software program 
34 that provides a standard PC Communication Port In- 
terface. A second software application 35 provides tel- 
ephone functionality to the PC 13 and is interfaced to 
the multiplexor/demultiplexor 33 via a Telephony Switch 
Interface application 36 also well-known in the art. A typ- 
ical example of such a switch interface capability is the 
Telephony Switch Provider (TAPI SP) which supports 
the Microsoft Telephony Services standard - a standard 
managed by the Microsoft Corporation. The telephony 
functionality on a computer is commonly referred to as 
Computer Telephone Integrated (CTI) software. The 
CTI software includes telephone functions such as call 
control (e.g. initiate calls and conference calls) and call 
monitoring such as may be used call center applica- 
tions. The functions are initiated by functional signaling 
messages sent to the adapter circuit 20 as described 
below. The telephony switch interface 36 handles the 
access data stream required for this functionality. Each 
of the software interfaces 34 and 36 in effect provide a 
respective virtual port from which the multiplexor 33 re- 
ceives and prepares a single channel data stream suit- 
able for transmission between the interface circuits. 
Since the data from each of the virtual ports must be 
distinguishable from one another, the multiplexing is 
achieved using a predetermined protocol as discussed 
below. The multiplexor/demultiplexor 33 may be imple- 
mented in software, for example, as a Windows Dynam- 
ic Load Library unit. 

The adapter circuit 20 is adapted to be connected 
to a TCM port of the KSU 10 via a TCM interface circuit 
43 which translates the 2B+D data of the TCM link from 
the KSU 10 to separate B1, B2, and D-channel data 
streams. As described above, the D-channel carries sig- 
naling and control data at 16 kb/s whereas each of the 
B-channels carries 64 kb/s data. The adapter circuit is 
also adapted to be connected to a digital key set via a 
TCM interface circuit 44 which translates D-channel sig- 
naling data and B1 -channel voice data into a TCM data 
stream. In this embodiment, the TCM interface circuits 
43 and 44 may conveniently be integrated circuit chips 
C84 and A42 respectively; these circuits were previous- 
ly utilized in the Norstar system and are described in the 
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aforementioned documents. A multiplexor/demultiplex- 
or 37 is connected to the interface circuit 31 and func- 
tions in a manner identical to multiplexor/demultiplexor 
33; it may therefore be implemented using similar soft- 
ware, s 

The adapter circuit 20 includes a processor 38 suit- 
ably programmed for controlling the operation of the 
adapter circuit as described below. A D-channel multi- 
plexor 42 is connected between multiplexor/demulti- 
plexor 37 t a D-channel port to the key set and a D-chan- 
nel port to the KSU; it merges D-channel traffic to and 
from the KSU to the PC telephony software, the at- 
tached key set and a data call controller 39. The data 
call controller 39 monitors the D-channel traffic on the 
D-channel multiplexor 42 to identify calls being directed 
to the key set or calls being originated by the user. In 
response to voice call origination activity the controller 
39 connects the B1 -channel from the KSU to the 
B1 -channel of the key set using a switch shown symbol- 
ically at 40 as a mechanical switch. Of course, this func- 
tion is actually realized using an electronics switch of 
conventional design. A data multiplexor 41 functions to 
prepare the data for the multiplexor/demultiplexor 37. 
Depending on the use of the key set, the data multiplex- 
or receives and sends either B1+B2 (128 kb/s) data or 
only B2 (64 kb/s) data. The data handling within the mul- 
tiplexor 41 conforms with the "PPP Multilink Protocol 
(MP)", RFC 1990, UCB/Lloyd Internetworking/New- 
bridge Networks Corporation/Sidewalk Software, Au- 
gust 1996. 

As is evident from the above description, the serial 
data stream on the RS-232E link between the PC 13 
and the adapter circuit 20 contains data related to both 
telephony and data functionalities. Depending on the 
use of the key set, the data stream to a remote computer 
or data terminal may be 64 kb/s or 1 28 kb/s. It is there- 
fore necessary to structure the data stream in accord- 
ance with a protocol that ensures the recognition by the 
multiplexors/demultiplexors 33 and 37 of the various 
types of data. 

Three separate data streams are defined that can 
cross the serial link: these are the raw data stream, the 
access stream and the link control stream. The data 
stream is transmitted as a byte stream having the ac- 
cess stream and the link control stream encapsulated 
therein. Figure 4 illustrates the software structure and 
functioning of the multiplexor/demultiplexor to achieve 
the RS-232E compatible data stream for transmission 
by the serial port 30. 

The data application 34 and the telephony applica- 
tion 36 each communicate with a respective virtual serial 
port of the mux/demux 33. The term "virtual serial port" 
is not meant to imply a particular implementation; it sim- 
ply indicates that the software above the mux/demux 33 
believes that it is communicating in a normal manner 
over a serial interface of the computer. As shown in Fig- 
ure 4, the messages are put through processes of en- 
capsulation and framing. All streams go through a proc- 
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ess of transparency substitution to allow flags to be used 
to delineate the complete messages from the applica- 
tions. Of course, the same data handling functionality is 
present at each end of the data link. 

Encapsulation is used to distinguish message types 
within the message based streams and to provide a de- 
gree of error detection. On transmission, a single byte 
value is added to the front of the message; the value of 
the byte depends on the message type (MT). On recep- 
tion, this byte is stripped from the message and used to 
determine the destination of the message. Additionally, 
a checksum in the form of an LRC (longitudinal redun- 
dancy check) is added to the message for transmission. 
This can be checked on reception to determined if errors 
occurred during transmission. The LRC is an eight bit 
value and is calculated on the entire message including 
the message type such that the successive exclusive- 
ORing of all bytes is zero, including the LRC. Of course, 
other types of error detection mechanisms could be em- 
ployed without departing from the concept and spirit of 
the invention. 

Two message type values are specified in this ex- 
ample embodiment; the value Ox04 is used for link con- 
trol messages and Ox06 is used for access messages. 
Other values can of course be used for other types of 
messages. 

Transparency is required to allow flag characters to 
be used as message delimiters for the access and link 
control streams. The transparency substitution process 
is shown in the Table of Figure 5A. This process is sim- 
ilar to that used for the Point-to-Point Protocol (PPP) 
over octet-synchronous links. Further information on 
PPP may be obtained from the articles "PPP in HDLC- 
like Framing, RFC 1662, Daydreamer, July 1994" and 
"The Point-to-Point Protocol (PPP), RFC 1661, Day- 
dreamer, July 1994". 

In data to be transmitted, including the raw data 
from the data applications, all occurrences of the flag 
character and a character called the control-escape 
character are replaced with a two-character sequence 
consisting of the control-escape character and the es- 
cape character exclusive-ORed with Ox20. 

Framing of a message is achieved by the addition 
of a flag character Ox7E to the beginning and the end 
of the message to be transmitted. Shared flags cannot 
be used between encapsulated messages since the da- 
ta stream is not encapsulated. 

Figure 5b illustrates the encapsulation and framing 
of access messages. All D-channel messages received 
without error from the KSU are encapsulated, passed 
through for transparency, framed and then transmitted 
on the serial data link. All messages received at the 
adapter circuit 20 on the serial data link as part of the 
access stream are striped of flags and have their trans- 
parency and encapsulation removed before being sent 
to the KSU. The message itself is not checked and is 
assumed to be a valid D-channel stimulus or functional 
message. 
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Figure 5c illustrates the format of a link control mes- 
sage. The link control stream comprises link control 
messages that are encapsulated and framed. They are 
used to configure the link between the adapter circuit 20 
and the PC 1 3. 

The type field is an 8-bit byte defining the link control 
message function. Parameters sent depend on the mes- 
sage sent and the parameter field length depends on 
the message type; it is always fixed for each message 
type and can be zero. The various link control messages 
will be described without value definitions as these are 
generally arbitrary. 

Acknowledgement Message 

This message is used by the adapter circuit 20 to 
acknowledge the reception of a link control message 
from the PC 1 3 that normally would require no response. 
The parameter field contains the type field of the mes- 
sage that was received and acted upon and is a length 
of one. A parameter field of 0x00 indicates that a mes- 
sage was received in error, and is therefore the equiva- 
lent of a negative acknowledgement. An unsupported 
message by the adapter circuit 20 is treated as a mes- 
sage with an error, and will receive a negative acknowl- 
edgement in response. The DLL will have no way of tell- 
ing if a line error occurred or if the message is unsup- 
ported, except by repeated attempts of the same mes- 
sage. 

Set Link Rate 

This message is used by the PC 13 to set the rate 
of the serial port link. If the message is received properly 
by the circuit, it responds with an Acknowledgement 
message at the original port rate. Immediately after 
sending the message, the adapter circuit changes its 
port rate to that specified in the original command. 

Query Hardware ID 

This message is used by the PC 13 to retrieve the 
adapter circuit's internal hardware ID; in response, it 
sends the Hardware ID message. 

Hardware ID 

The message returns the adapter circuit's hardware 
ID in response to Query Hardware ID message. The pa- 
rameter of this message is a 40-bit hardware ID of the 
adapter circuit. 

Bad KSU Message Indication 

When the adapter circuit detects a bad message 
from the KSU, a message indicating this is sent to the 
PC. No indication of the type of error or the possible 
message type is provided. There is no response expect- 



ed from this message, so no recovery is possible if there 
was an error in transfer of this message. This message 
is provided so that error logs may be kept. 

s Bad Key Set Message Indication 

When the adapter circuit detects a bad message 
from the attached key set. a message indicating this is 
sent to the PC. No indication of the type of error or the 
10 possible message type is provided. There is no re- 
sponse expected from its message, so no recovery is 
possible if there was an error in transfer of this message. 
This message is also provided so that error logs may be 
kept. 

15 

Capabilities and Status Parameter Format 

The parameter used by the Capabilities, Enable Ca- 
pabilities and Status link control messages is a single 

20 byte representing a bit map. All bits are active high for 
both capability, enabling and status where appropriate. 
Each bit is used to indicate a particular status or capa- 
bility such as key set interface being attached, frame 
synchronization status, rate adaptation availability, one 

25 or both B-channel availability and other optional capa- 
bilities. 

Query Capabilities 

30 This message is used to allow the PC to query the 
capabilities of the adapter circuit's current firmware 
load. It expects the Capabilities message to be returned. 

Capabilities 

35 

This message is used to indicate the capabilities of 
the adapter circuit's current firmware load; it is sent in 
response to the Query Capabilities message. 

40 Enable Capabilities 

This message is used by the PC to enable and dis- 
able the capabilities of the adapter circuit. Upon suc- 
cessful completion of the command, the Acknowledge- 
rs ment message is sent to the PC. Failure to complete the 
command results in a negative acknowledgement mes- 
sage sent to the PC. An attempt to enable an unsup- 
ported capability is ignored, and will not return a nega- 
tive acknowledgement. 

so 

Query Status 

This message is used to allow the PC to query the 
current status of the adapter circuit. It expects the Status 
55 message to be returned. 
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Status 

This message is used to indicate the status of the 
adapter circuit and is sent in response to the Query Sta- 
tus message. 

Break Start 

This message is sent to indicate that a break char- 
acter has been inserted into the data stream path. The 
break condition exists until the Break End message is 
received. This message can be sent in either direction 
by applications or rate adaptation protocols that support 
it. 

Break End 

This message is sent to indicate that a break char- 
acter that was previously inserted into the data stream 
path is now removed. It is ignored if there was no pre- 
vious Break Start character. This message can be sent 
in either direction by applications or rate adaptation pro- 
tocols that support it. 

Figure 5d illustrates the data stream format of the 
raw data from the data virtual serial port. The data is 
treated for transparency but is not encapsulated or 
framed. The data appears between messages encap- 
sulated by flag characters. When the Point-to-Point for- 
mat is used over the message stream, characters es- 
caped in the PPP message will result in two escapes 
being generated. One of the escapes is removed by the 
interface multiplexors whereas the second one is re- 
moved by the PPP implementation. 

The operation of the circuit arrangement will now be 
described briefly with particular reference to figure 3 and 
figure 6. Under quiescent operation, the adapter circuit 
20 interfaces a key set to a KSU, the mux/demux 37 and 
33 are not used and are not aware of each other's ex- 
istence. It is up to the access application in the PC 13 
to install or energize its interface software to the serial 
data link. This is done either when the PC starts up or 
the interface software is installed; otherwise the inter- 
face software is running all the time. The interface soft- 
ware takes over the use and control of the serial data 
port and provides the two virtual serial ports for the data 
and access applications. Through an exchange of data 
link messages, the PC requests the interface circuitry of 
the adapter circuit to become active resulting in the re- 
spective interfaces of the PC 13 and the adapter circuit 
20 being in the data stream mode. If a first attempt at 
reestablishing the serial data link fails, the PC will try 
further attempts after ascertaining that the set-up con- 
ditions are in place. The PC interface software estab- 
lishes the status of the adapter circuit 20 through the 
use of a query-response mechanism using standard AT- 
commands well-known in the art. The routing of re- 
ceived data and messages at each end of the data link 
depends on the detection of the flag characters that are 



used to frame access, link control and other types of 
messages as well as synchronization on the fink. 

Figure 6 illustrates a multiplexer/demultiplexer re- 
ceiver state machine. The initial state of the receivers is 

s to assume that it is not in a message state. When it is 
not in a message state, all received characters are con- 
sidered data bytes. However, the reception of a flag 
character causes all characters received subsequently, 
until the next flag character, to be considered part of a 

10 message. The first character after the flag character in- 
dicates the destination of the message. After the second 
flag is received, the next character is assumed to be da- 
ta unless it is another flag character. 

At the termination of a data session on the serial 

is data link, the interfaces are set to idle and may be reac- 
tivated by initialization by the PC interface software us- 
ing a query-response mechanism as mentioned above. 

As may be realized from the above description, the 
circuit arrangement of the invention provides the capa- 

20 bility to a user on the switch to access data services such 
as internet network service providers. Since the circuit 
arrangement acts like a high-speed modem and pro- 
vides a data stream compatible with ISDN, it results in 
lower equipment cost and a higher data rate than that 

25 obtained by use of a modem. Since the circuit uses a 
serial port, it is platform independent and can be imple- 
mented on PCs, Macintoshes and other computers; it is 
also compatible with all software adapted to function 
through a serial port and with the commonly used ex- 

30 tended Hayes AT-command set. 

The invention can be summarized as follows. A cir- 
cuit arrangement is provided for connecting a personal 
computer (PC) to a port of a key telephone system via 
an adapter circuit which also interfaces a digital key set 

35 to the port. The adapter circuit is connected to the com- 
puter via an RS-232 single channel data link. The PC is 
programmed to generate and receive a serial data 
stream into which are encapsulated messages relating 
to link control and telephone functionality. The adapter 

40 circuit is also programmed to receive and generate the 
serial data stream. The data rate through the adapter 
circuit and the telephone system and hence to a remote 
computer is dependent on the utilization of the attached 
key set by the user to make a call. 

45 it will of course be recognized that the invention can 
be realized using variations of the circuit arrangement 
described above without departing from the scope and 
spirit of the invention. 



so 



Claims 



55 



A circuit arrangement for providing simultaneous 
telephone functionality and data connectivity to a 
personal computer (PC) connected to a key tele- 
phone system, the system including a key service 
unit (KSU) and a plurality of digital key sets, the PC 
being connected to a port of the KSU and to one of 
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the digital key sets via an adapter circuit, the port 
being adapted to carry a pair of data channels (2B) 
and a signaling and control channel (D) to provide 
a 2B+D TCM link, the circuit arrangement compris- 
ing: 5 

an adapter circuit having a first TCM port for 
connection to the port of the KSU, a second 
TCM port for connection to the digital key set 
and a third port for connection to the PC, the io 
third port comprising a first circuit for interfacing 
to single channel serial data; 
a PC suitably programmed to provide tele- 
phone functionality by generating and respond- 
ing to telephone signaling and control data and 
to provide data generation and reception func- 
tionality, the PC comprising a second circuit for 
interfacing to single channel serial data port 
and being further suitably programmed to mul- 
tiplex and demultiplex data generated in the re- 20 
alization of the telephone and data functionali- 
ties for generating a single channel data stream 
suitable for transmission between the first and 
second interfacing circuits in accordance with 
a predetermined protocol; 2s 
the adapter circuit further comprising a proces- 
sor, control circuitry, and a multiplexor/demulti- 
plexor circuit for multiplexing TCM data to sin- 
gle channel serial data and demultiplexing sin- 
gle channel serial data to TCM data in accord- 30 
ance with the predetermined protocol, the con- 
trol circuitry being responsive to commands 
from the processor to route signaling data to 
and from the key set and the PC to the KSU 
and to always route one of the B-channels to 35 
the key set when it is in use and to otherwise 
connect both B-channels to the PC. 

A method of providing telephony and data connec- 
tivity between a personal computer (PC) and a 40 
2B+D channels TCM (Time Compression Multiplex) 
port on a key telephone system, the PC being suit- 
ably programmed to provide telephony functions as 
well as data handling functions including telephone 
line dialing capability and having an interface circuit 45 
to a single channel serial data port, the arrangement 
further comprising an adapter circuit including a 
controller and having first circuit means for interfac- 
ing to a signal path connected to the TCM port on 
the key telephone system, second circuit means for so 
connection to a key set, the interfacing circuit 
means providing access ports corresponding to a 
D-channel, a B1 -channel and a B2 -channel, the 
adapter circuit also having an interface circuit for a 
single channel serial data port, the serial data ports ss 
of the PC and the adapter circuit being connected 
by a serial communications link, the method of the 
invention comprising the steps of: 



in the adapter circuit, multiplexing the data on 
the D and B-channels into a single channel se- 
rial data stream using a predetermined protocol 
and demultiplexing the received serial data 
stream into D and B-channel data; 
in the PC, demultiplexing the serial data stream 
to reconstitute the 2B+D data, and multiplexing 
the 2B+D data generated in the PC for trans- 
mission on the serial communications link; 
whereby the data related to the telephony func- 
tions are encapsulated in the serial data stream 
which provides a high speed data communica- 
tions link to the key telephone system and 
thence to the telephone network. 

3. A method as defined in claim 2 and comprising the 
further steps of: 

the adapter circuit responding to the estab- 
lishment of a data call by allocating the B-channels 
to the call. 

4. A method as defined in claim 2 or claim 3 and com- 
prising the further steps of: 

the adapter circuit recognizing functional sign- 
aling corresponding to requested use by a user 
for a voice call; 

in response to the recognition, forwarding the 

signaling to the key system on the D-channel 

of the TCM link thereto; and 

on establishment of the requested voice call, 

allocating one of the B-channels to the voice 

call. 

5. A method as defined in claim 4 wherein if a data call 
is established during a voice call, the data call is 
allocated to the other B-channel. 

6. A method as defined in claim 5 wherein if a voice 
call terminates while a data call is in progress, the 
B-channel that was used for the voice call is also 
allocated to the data call. 

7. A circuit arrangement for providing simultaneous 
telephone functionality and data connectivity be- 
tween a personal computer (PC) and a time com- 
pression multiplex (TCM) port on a key telephone 
system, comprising: 

an adapter circuit comprising a controller circuit 
and having circuit means for interfacing to a 
TCM signal path connected to the TCM port on 
the key telephone system, the TCM path for 
carrying 2B+D channels of data, the interfacing 
circuit means being controlled to decompose 
and recompose the TCM signal to provide sig- 
nals corresponding to a D-channel, a B1 -chan- 
nel and a B2-channel on respective data ports 
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thereof, the adapter circuit also comprising, a 
serial port interface circuit, and a multiplexor/ 
demultiplexer circuit for translating the 2B+D 
channel data to a single channel data stream 
under control of the controller circuit; 5 
a PC suitably programmed to provide telepho- 
ny functions as well as data handling functions 
including telephone line dialing capability, the 
PC comprising an interface circuit for a single 
channel serial data port and being further suit- 10 
ably programmed to multiplex and demultiplex 
data generated for telephony functions and for 
data handling functions to and from a data 
stream on the single channel serial data port; 
and is 
a serial data link for connecting the single chan- 
nel serial data port interface circuit of the PC to 
the serial port interface circuit of the adapter cir- 
cuit. 



8. A circuit arrangement as defined in claim 7 wherein 
messages of various types are encapsulated in the 
serial data stream between the PC and the adapter 
circuit. 

9. A circuit arrangement as defined in claim 8 wherein 
the encapsulation is achieved by framing each mes- 
sage with a flag character at the beginning and end 
thereof. 



20 



25 



30 



10. A circuit arrangement as defined in claim 9 wherein 
all occurrences of a flag character and a control- 
escape character are replaced with a two-character 
sequence consisting of the control-escape charac- 
ter and the escaped character exclusive-ORed with 3S 
a predetermined byte value thereby allowing the 

flag characters to be used.as message delimiters. 

for the messages in the raw data stream while pro- 
viding transparency for control bytes within the 
messages. 40 

11. A circuit arrangement as defined in any one of 
claims 7 to 10 wherein each message is provided 
with a data field corresponding to the type of mes- 
sage. 



45 



12. A circuit arrangement as defined in any one of 
claims 7 to 11 wherein each message contains a 
checksum byte for determining the correct recep- 
tion of the message. 3 so 

1 3. A circuit arrangement as defined in claim 1 2 where- 
in the checksum byte is in the form of a longitudinal 
redundancy check. 

55 
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